草庐IT

sql - 做一个计数 MySQL 查询?

全部标签

ruby-on-rails - 如何在 Rails 中使用 gem 'acts-as-taggable-on' 时获取所有标签的列表(不是计数)

我在我的模型中设置了acts-as-taggable-ongem,如下所示:acts_as_taggable_on:deshanatags它使用上下文deshanatags。现在我需要在上下文中以下列格式获取所有标签的列表(不仅仅是为一个项目分配的标签。我需要所有标签):[{"id":"856","name":"House"},{"id":"1035","name":"DesperateHousewives"}]我该怎么做?我尝试遵循许多教程,但遇到了死胡同,因为它们中的大多数都是为Rails3编写的。Rails对模型进行了一些更改,例如删除了attr_accessor,这让我很难理解

ruby - 一个在 Ruby 上表现非常糟糕的简单正则表达式

我有一个简单的Ruby正则表达式,需要很长时间才能计算:"fußball"*20=~/^([\S\s]{1000})/i如果我删除/i标志,它会工作得非常快。为什么运行这么慢?(我没有等到执行完毕)我知道这个正则表达式可能没有意义,但我想知道幕后是什么。错误报告:https://bugs.ruby-lang.org/issues/14418 最佳答案 默认.不匹配换行符。[\s\S]是解决该问题的方法。在Ruby中,您可以使用/m标志使点匹配所有字符。它在文档中RubyMetacharactersandEscapes[\S\s]由于

ruby - 为什么模块 `ClassMethods` 在同一个命名空间中定义和扩展?

我正在尝试理解来自githubrepo的代码.它是设置客户端的gem的主要模块。moduleGithub#morecodeclass为什么是class和moduleClassMethods使用,然后扩展而不是包含在class中部分?有一个类方法defincluded(base).这似乎将类方法添加到特定对象中。为什么会这样?它可能与类的功能有关,但我不明白。 最佳答案 moduleMyModuleclassendend这实际上是Ruby中很常见的做法。基本上,它的意思是:当某个对象执行includeMyModule时,也使它也ext

ruby-on-rails - 将查询字符串附加到 url

我有一个回调url字符串params[:callback],我需要附加一个查询字符串"&result=true"并重定向用户。我发现这样做的更好方法是使用addressable但我认为代码对于这样的任务来说太大了,尤其是当我们谈论ruby​​时:callback=Addressable::URI.parse(params[:callback])query=callback.query_valuesquery[:result]='true'callback.query_values=queryredirect_tocallback.to_s是否有更优雅的方式来获得与此代码段相同的结果?

Ruby:如何检查一个字符串是否包含多个项目?

我熟悉Ruby的include?字符串方法,但我如何检查一个字符串的多个内容?具体来说,我需要检查字符串是否包含“Fwd:”或“FW:”(并且应该不区分大小写)示例字符串为:“FWD:您的Amazon.com订单已发货” 最佳答案 the_string=~/fwd:|fw:/i你也可以使用类似的东西%w(fwd:fw:).any?{|str|the_string.downcase.include?str}虽然我个人更喜欢在这种情况下使用正则表达式的版本(特别是因为你必须在第二个中调用downcase以使其不区分大小写)。

ruby-on-rails - 如何获取触发查询的代码行?

在rails3.2中是否有一种方法(一个gem、一个插件或其他东西)来知道哪一行代码触发了一个数据库查询?例如在我的日志中我有:UserLoad(0.4ms)SELECT`users`.*FROM`users`WHERE`users`.`id`=5LIMIT1如何知道触发查询的代码行?谢谢... 最佳答案 我找到了这个解决方案:moduleQueryTracedefself.enable!::ActiveRecord::LogSubscriber.send(:include,self)enddefself.append_featur

ruby - 如何在 Ruby 中要求一个 block ?

是否有任何内置方法要求将block传递给Ruby方法?我意识到如果block_given?为false,我可以引发异常,但是否有更好的方法来做到这一点? 最佳答案 只需使用yield。如果您在方法中包含yield,但未给出block,则会抛出错误。将其放入文件中并运行:defneeds_blockyieldendneeds_block它会抛出这样的错误:LocalJumpError:noblockgivenfrom(irb):14:in`needs_block'from(irb):16

sql - ActiveRecord::StatementInvalid。 PG错误

我正在尝试使用Project.find(id)从Project模型中找到一个项目,但它给了我ActiveRecord::StatementInvalid错误完整跟踪-PG::Error:ERROR:preparedstatement"a1"alreadyexists:SELECTCOUNT(*)FROMpg_classcLEFTJOINpg_namespacenONn.oid=c.relnamespaceWHEREc.relkindin('v','r')ANDc.relname=$1ANDn.nspname=ANY(current_schemas(false))/home/deploy

ruby-on-rails - ruby 将回形针附件从一个模型复制到另一个模型?

我有两个这样的模型:-模型1-卡片-包含首页感兴趣的数据表示附件名称=cardimage模型2-用户-包含用户附件名称=头像当我创造!一张新卡片,我希望将用户模型中的头像作为新卡片图像复制到卡片模型中。是否有一个简单的衬垫?Ruby/Rails/回形针 最佳答案 这应该可以解决问题,如果模型关联,您可以使用after_create回调,否则我建议在创建卡片的Controller操作中执行此操作。instance_of_model_one.cardimage=instance_of_model_two.avatarinstance_o

ruby - 是否可以做一个不区分大小写的 `gsub` ?

我正在执行gsub以将“bad”换成“good”。有没有办法使用capitalize来交换大小写?或者我必须写两次def吗?defadd_more_ruby(string)string.gsub('bad','good').capitalizeend 最佳答案 你可以通过Regexp而不是String,使用i选项指示此正则表达式不区分大小写:defadd_more_ruby(string)string.gsub(/bad/i,'good')end请注意,它不仅会替换'bad'和'BAD',而且还会替换'bAd'。如果你只想替换全大写